home *** CD-ROM | disk | FTP | other *** search
/ User's Choice Windows CD / User's Choice Windows CD (CMS Software)(1993).iso / misc1 / iv26_w30.zip / EXAMPLES / IDRAW / LISTGROU.C < prev    next >
C/C++ Source or Header  |  1980-01-05  |  2KB  |  57 lines

  1. /*
  2.  * Copyright (c) 1987, 1988, 1989 Stanford University
  3.  *
  4.  * Permission to use, copy, modify, distribute, and sell this software and its
  5.  * documentation for any purpose is hereby granted without fee, provided
  6.  * that the above copyright notice appear in all copies and that both that
  7.  * copyright notice and this permission notice appear in supporting
  8.  * documentation, and that the name of Stanford not be used in advertising or
  9.  * publicity pertaining to distribution of the software without specific,
  10.  * written prior permission.  Stanford makes no representations about
  11.  * the suitability of this software for any purpose.  It is provided "as is"
  12.  * without express or implied warranty.
  13.  *
  14.  * STANFORD DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
  15.  * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS.
  16.  * IN NO EVENT SHALL STANFORD BE LIABLE FOR ANY SPECIAL, INDIRECT OR
  17.  * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
  18.  * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
  19.  * OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
  20.  * WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  21.  */
  22.  
  23. // $Header: listgroup.c,v 1.3 89/10/09 14:48:43 linton Exp $
  24. // implements class GroupNode.
  25.  
  26. #include "listgroup.h"
  27. #include "listselectn.h"
  28. #include "selection.h"
  29.  
  30. // GroupNode stores the parent, boolean value, children, and the
  31. // children's original graphic states.
  32.  
  33. GroupNode::GroupNode (PictSelection* p, boolean h, SelectionList* sl) {
  34.     parent = p;
  35.     haschildren = h;
  36.     children = new SelectionList;
  37.     childrengs = new SelectionList;
  38.     for (sl->First(); !sl->AtEnd(); sl->Next()) {
  39.     Selection* child = sl->GetCur()->GetSelection();
  40.     Selection* childgs = new Selection(child);
  41.     children->Append(new SelectionNode(child));
  42.     childrengs->Append(new SelectionNode(childgs));
  43.     }
  44. }
  45.  
  46. // Free storage allocated to list the children and allocated
  47. // for their graphic states.
  48.  
  49. GroupNode::~GroupNode () {
  50.     delete children;
  51.     for (childrengs->First(); !childrengs->AtEnd(); childrengs->Next()) {
  52.     Selection* s = childrengs->GetCur()->GetSelection();
  53.     delete s;
  54.     }
  55.     delete childrengs;
  56. }
  57.